Ext.onReady(function ()
{
	//获得数据store
	var environmentData = Ext.create('Ext.data.Store',
		{
			model : 'EnvironmentModel',
			proxy :
			{
				type : 'ajax',
				url : basePath + 'room/getEnvironmentList',
				reader :
				{
					type : 'json',
					root : 'root'
				}
			},
			autoLoad : true
		}
		);

	function addForm()
	{
		if (addNewEnvironmentForm.getForm().isValid())
		{
			addNewEnvironmentForm.getForm().submit(
			{
				url : basePath + 'room/addNewEnvironment',
				method : 'POST',
				waitMsg : '正在添加，请稍候...',
				waitTitle : '添加中',
				timeout : 300000,
				params : addNewEnvironmentForm.getValues(),
				success : function (addNewEnvironmentForm, action)
				{
					var isSuc = action.result.success;
					if (isSuc)
					{
						Ext.Msg.alert('添加成功！', '已经完成添加，您可以继续配置实验室环境！');
						environmentGrid.store.removeAll();
						environmentGrid.store.reload();
						addWindow.close();
					}
					else
					{
						var res = action.result.res;
						Ext.Msg.alert('添加失败', res);
					}
				},
				failure : function (addCourseForm, action)
				{
					var res = action.result.res;
					Ext.Msg.alert('添加失败', res);
				}
			}
			);
		}
	}

	function editForm()
	{
		if (editEnvironmentForm.getForm().isValid())
		{
			editEnvironmentForm.getForm().submit(
			{
				url : basePath + 'room/editEnvironment',
				method : 'POST',
				waitMsg : '正在修改，请稍候...',
				waitTitle : '修改中',
				timeout : 300000,
				params : editEnvironmentForm.getValues(),
				success : function (editEnvironmentForm, action)
				{
					var isSuc = action.result.success;
					if (isSuc)
					{
						Ext.Msg.alert('修改成功！', '已经完成修改！');
						environmentGrid.store.removeAll();
						environmentGrid.store.reload();
						editWindow.close();
					}
					else
					{
						var res = action.result.res;
						Ext.Msg.alert('修改失败', res);
					}
				},
				failure : function (addCourseForm, action)
				{
					var res = action.result.res;
					Ext.Msg.alert('修改失败', res);
				}
			}
			);
		}
	}

	var columns = [
		{
			header : '名称',
			dataIndex : 'name',
			width : '20%'
		},
		{
			header : '描述',
			dataIndex : 'information',
			width : '80%'
		}
	];

	var EnvironmentNameBox = Ext.create('Ext.form.ComboBox',
		{
			fieldLabel : '要修改的环境:',
			emptyText : '请选择要修改的环境',
			labelWidth : 100,
			width : 550,
			store : environmentData,
			queryMode : 'local',
			editable : false,
			name : 'environment_id',
			hiddenName : 'environment_id',
			displayField : 'name',
			valueField : 'environment_id',
			blankText : '不能为空',
			allowBlank : false,
			listeners :
			{
				'select' : function ()
				{
					var index = environmentData.find('environment_id', EnvironmentNameBox.getValue());
					nameText.setValue(environmentData.getAt(index).get('name')); //获取eid对应描述信息
					informationText.setValue(environmentData.getAt(index).get('information')); //获取eid对应描述信息
				}
			}
		}
		);

	var environmentGrid = new Ext.grid.GridPanel(
		{
			title : '环境列表',
			frame : false,
			selModel : new Ext.selection.RowModel(),
			store : environmentData,
			enableHdMenu : false,
			enableColumnHide : false,
			columnLines : true,
			columns : columns,
			stripeRows : true,
			loadMask : true,
			renderTo : 'showEnvironmentInfoDiv',
			listeners :
			{
				'select' : function (selModel, record, index, eOpts)
				{
					selRecord = record;
				}
			},
			buttons : [
				{
					text : '新增',
					handler : function ()
					{
						addWindow.show();
					}
				},
				{
					text : '编辑',
					handler : function ()
					{
						editWindow.show();
						var index = environmentData.find('environment_id', selRecord.get('environment_id'));
						EnvironmentNameBox.select(selRecord);
						nameText.setValue(environmentData.getAt(index).get('name')); //获取eid对应描述信息
						informationText.setValue(environmentData.getAt(index).get('information')); //获取eid对应描述信息
					}
				}
			]
		}
		);

	var tmp = Ext.getCmp('addNewEnvironmentForm');
	if (tmp != null)
		tmp.destroy();
	var addNewEnvironmentForm = Ext.create("Ext.form.FormPanel",
		{
			title : '添加一个新的环境',
			frame : false,
			defaultType : 'textfield',
			defaults :
			{
				labelWidth : 100,
				labelAlign : "right"
			},
			items : [
				{
					allowBlank : false,
					fieldLabel : '环境名称',
					name : 'name',
					emptyText : '输入名称',
					width : 550
				},
				new Ext.form.TextArea(
				{
					allowBlank : false,
					name : 'information',
					emptyText : '请输入对环境的详细描述',
					width : 550,
					height : 200,
					fieldLabel : '环境详细信息'
				}
				)
			],
			buttons : [
				{
					text : '确定',
					handler : function ()
					{
						addForm();
					}
				}
			]
		}
		);
	var addWindow = Ext.create('Ext.window.Window',
		{
			title : '新增环境',
			height : 400,
			width : 600,
			layout : 'fit',
			modal : true,
			closeAction : 'hide',
			items : [addNewEnvironmentForm]
		}
		);

	function delForm(Button)
	{
		if (Button != 'yes')
			return;
		editEnvironmentForm.getForm().submit(
		{
			url : basePath + 'room/deleteEnvironment',
			method : 'POST',
			waitMsg : '正在删除，请稍候...',
			waitTitle : '删除中',
			timeout : 300000,
			params : {},
			success : function (editEnvironmentForm, action)
			{
				var isSuc = action.result.success;
				if (isSuc)
				{
					EnvironmentNameBox.store.removeAll();
					EnvironmentNameBox.store.reload();
					EnvironmentNameBox.setValue('');
					Ext.Msg.alert('删除成功！', '已经成功删除！');
					editWindow.close();
				}
				else
				{
					var res = action.result.res;
					Ext.Msg.alert('删除失败', res);
				}
			},
			failure : function (editEnvironmentForm, action)
			{
				var res = action.result.res;
				Ext.Msg.alert('删除失败', res);
			}
		}
		);
	}

	var informationText = new Ext.form.TextArea(
		{
			allowBlank : false,
			name : 'information',
			emptyText : '请输入对环境的详细描述',
			width : 550,
			height : 200,
			fieldLabel : '环境详细信息'
		}
		);

	var nameText = new Ext.form.Text(
		{
			allowBlank : false,
			fieldLabel : '环境名称',
			name : 'name',
			emptyText : '输入名称',
			width : 550
		}
		);

	var tmp = Ext.getCmp('editEnvironmentForm');
	if (tmp != null)
		tmp.destroy();
	var editEnvironmentForm = Ext.create("Ext.form.FormPanel",
		{
			title : '编辑已存在的环境',
			frame : false,
			defaultType : 'textfield',
			defaults :
			{
				labelWidth : 100,
				labelAlign : "right"
			},
			items : [
				EnvironmentNameBox,
				nameText,
				informationText
			],
			buttons : [
				{
					text : '确定',
					handler : function ()
					{
						editForm();
					}
				},
				{
					text : '删除',
					handler : function ()
					{
						Ext.Msg.show(
						{
							title : "删除",
							msg : "是否要删除？这样所有实验室的该环境都会被清空",
							buttons : Ext.Msg.YESNO,
							fn : delForm,
							icon : Ext.MessageBox.QUESTION
						}
						);
					}
				}
			]
		}
		);

	var editWindow = Ext.create('Ext.window.Window',
		{
			title : '编辑环境',
			height : 400,
			width : 600,
			layout : 'fit',
			modal : true,
			closeAction : 'hide',
			items : [editEnvironmentForm]
		}
		);
}
);
